Unset tooltip window earlier
authorMatthias Clasen <mclasen@redhat.com>
Sat, 9 May 2020 20:46:40 +0000 (16:46 -0400)
committerMatthias Clasen <mclasen@redhat.com>
Mon, 11 May 2020 16:20:59 +0000 (12:20 -0400)
This avoids a crash when the tooltip window tries
to update its action muxers.

gtk/gtktooltip.c
gtk/gtktooltipprivate.h
gtk/gtkwindow.c

index fc9e665444bf348633bd1b2307dbe95b61bdcf7e..4af709f19eca0dfc070754d70f640f28886bc114 100644 (file)
@@ -990,3 +990,17 @@ gtk_tooltip_maybe_allocate (GtkNative *native)
 
   gtk_native_check_resize (GTK_NATIVE (tooltip->window));
 }
+
+void
+gtk_tooltip_unset_surface (GtkNative *native)
+{
+  GdkDisplay *display = gtk_widget_get_display (GTK_WIDGET (native));
+  GtkTooltip *tooltip;
+
+  tooltip = g_object_get_qdata (G_OBJECT (display), quark_current_tooltip);
+  if (!tooltip || GTK_NATIVE (tooltip->native) != native)
+    return;
+
+  gtk_tooltip_set_surface (tooltip, NULL);
+}
+
index ca63406b2c11a6743b6c7b705e6e1118ed4220ce..8f48433775b17c6f6aad454abc109800209e43e3 100644 (file)
@@ -44,6 +44,7 @@ GtkWidget * _gtk_widget_find_at_coords   (GdkSurface         *surface,
                                           gint               *widget_y);
 
 void gtk_tooltip_maybe_allocate          (GtkNative          *native);
+void gtk_tooltip_unset_surface           (GtkNative          *native);
 
 G_END_DECLS
 
index c469ceb7d0738108c2fbf2a6618ddc4ab3afe2ad..ce94190e44b8a202f97a3053852cc58560a073fd 100644 (file)
@@ -7484,6 +7484,8 @@ gtk_window_destroy (GtkWindow *window)
 
   g_return_if_fail (GTK_IS_WINDOW (window));
 
+  gtk_tooltip_unset_surface (GTK_NATIVE (window));
+
   for (i = 0; i < g_list_model_get_n_items (G_LIST_MODEL (toplevel_list)); i++)
     {
       gpointer item = g_list_model_get_item (G_LIST_MODEL (toplevel_list), i);